<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
<link rel="stylesheet" type="text/css" href="../css/common.css" media="all" />
<link rel="stylesheet" type="text/css" href="../css/article.css" media="all" />
</head>
<body>
<div id="w3h_body">
  <div class="body_content">
    <!-- toc begin -->
    <h1 class="title">BX2033: 各浏览器对使用脚本将页面加入收藏夹的支持情况不同</h1>
    <ul class="toc">
      <li><a href="#standard_reference">标准参考</a> <span>•</span></li>
      <li><a href="#description">问题描述</a> <span>•</span></li>
      <li><a href="#influence">造成的影响</a> <span>•</span></li>
      <li><a href="#impacted_browsers">受影响的浏览器</a> <span>•</span></li>
      <li><a href="#analysis_of_issues">问题分析</a> <span>•</span></li>
      <li><a href="#solutions">解决方案</a> <span>•</span></li>
      <li><a href="#see_also">参见</a></li>
    </ul>
    <!-- toc end -->
    <div id="w3h_content">
      <!-- content begin -->
      <address class="author">作者：周涛</address>
      <h2 id="standard_reference">标准参考</h2>
      <p>无</p>

      <h2 id="description">问题描述</h2>
      <p>目前，IE Firefox Opera 提供了各自将当前页 URL 加入到浏览器的收藏夹中的接口，Chrome Safari 暂未提供相应接口。</p>

      <h2 id="influence">造成的影响</h2>
      <p>不同的浏览器对“加入收藏夹”的支持情况不同，Chrome Safari 不能通过脚本代码将当前页 URL 加入到浏览器的收藏夹中。</p>

      <h2 id="impacted_browsers">受影响的浏览器</h2>
      <table class="list">
        <tr>
          <th>所有浏览器</th>
          <td>&nbsp;</td>
        </tr>
      </table>

      <h2 id="analysis_of_issues">问题分析</h2>
      <p>加入收藏夹功能是由各浏览器厂商提供，非 W3C 规范范畴，他们的实现差异如下：</p>
      <p> IE 浏览器，使用 window.external.AddFavorite 方法添加到收藏夹。<br/>
        详见：<a href="http://msdn.microsoft.com/en-us/library/ms535926%28VS.85%29.aspx">http://msdn.microsoft.com/en-us/library/ms535926%28VS.85%29.aspx</a>。 </p>
      <p> Firefox 浏览器，使用 window.sidebar.addPanel 方法。<br/>
        详见：<a href="https://developer.mozilla.org/en/DOM/window.sidebar">https://developer.mozilla.org/en/DOM/window.sidebar</a>。 </p>
      <p>Opera 浏览器，可以给链接添加 title 和 rel 属性实现收藏功能（该方式也适合Firefox）；其中 title 属性就是网站的名称，rel 设置为 slidebar。如下：</p>
<pre>
&lt;a href=&quot;http://www.google.com&quot; title=&quot;Google&quot; rel=&quot;sidebar&quot;&gt;收藏本站&lt;/a&gt;
</pre>
      <p>Safari Chrome 浏览器目前未提供将页面添加到收藏夹接口。</p>

        <h2 id="solutions">解决方案</h2>
      <p>综合各浏览器提供的加入收藏夹的方法编写代码，并为没有提供相应接口的浏览器给出友好提示。如：</p>
<pre>
&lt;script type="text/javascript"&gt;
function addFavorite(url,title){
  if(window.sidebar||window.opera)return true;
  try{
    window.external.AddFavorite(url,title);
  }
  catch(e){
    alert("请按下 Ctrl + D 键将本站加入收藏。");
  }
  return false;
}
&lt;/script&gt;
&lt;a href="http://www.google.com" title="google" rel="sidebar" onclick="return addFavorite('http://www.google.com','Google');"&gt;加入收藏&lt;/a&gt;
</pre>

      <h2 id="see_also">参见</h2>
      <h3>知识库</h3>
      <ul class="see_also">
        <li><a href="#">...</a></li>
      </ul>
      <h3>相关问题</h3>
      <ul class="see_also">
        <li><a href="#">...</a></li>
      </ul>

      <div class="appendix">
        <h2>测试环境</h2>
        <table class="list">
          <tr>
            <th>操作系统版本:</th>
            <td>Windows 7 Ultimate build 7600</td>
          </tr>
          <tr>
            <th>浏览器版本:</th>
            <td>IE6<br />
              IE7<br />
              IE8<br />
              Firefox 3.6.8<br />
              Chrome 6.0.472.22 dev<br />
              Safari 5.0.1<br />
              Opera 10.60
            </td>
          </tr>
          <tr>
            <th>测试页面:</th>
            <td>&nbsp;</td>
          </tr>
          <tr>
            <th>本文更新时间:</th>
            <td>2010-08-06</td>
          </tr>
        </table>
        <h2>关键字</h2>  
        <!-- keywords begin -->
        <p>Favorite AddFavorite sidebar 加入收藏夹</p>
        <!-- keywords end -->
      </div>
      <!-- content end -->
    </div>
  </div>
</div>
</body>
</html>
